## **Group 8**

## Bug report - 6

- 1. Failing Test name Instruction cache Read Miss test with no free block available and replacement needed
- 2. Test description (Describe the planned scenario and the expected result)

  Performed a read\_miss\_icache test on L1 and L2 cache by giving the read requests to both the caches. Here L1

  Instruction cache read miss with no free block is available and it requires the LRU Replacement. Our test targets that L2 cache should through a read miss for the read request but from the log file and waveforms we observed that L1 cache is serviced instead of L2 cache.
- 3. Failing assertion that helped you identify the bug Scoreboard does not receive packets from system bus and throws error. Error message:

```
degith int 32 'dz
parent sequence (name) string 20 read_miss_icache_seq
parent sequence (full name) string 47 uvm_test_top.tb.vsequencer.

UVM_INFO ../uvm/cpu_monitor_c.sv(59) @ 1745: uvvm_test_top.tb.cpu[3].sequencer

UVM_INFO ../uvm/cache_scoreboard_c.sv(59) @ 1745: uvvm_test_top.tb.cpu[3].monitor [cpu_monitor_c] TRIGGERED ICACHE PACKET CREATION UVM_INFO ../uvm/cache_scoreboard_c.sv(539) @ 1765: uvvm_test_top.tb.sb [cache_scoreboard_c] cpu_mon_packet from CPU3:

Name Type Size Value

packet cpu_mon_packet_c @7671
dat integral 32 'haaaa5555
address integral 32 'haaaa5555
address integral 32 'haaaa5555
address integral 32 'haaaa5555
uvm_test_top.tb.sb [cache_scoreboard_c]
UVM_INFO ../uvm/cache_scoreboard_c.sv(293) @ 1765: uvm_test_top.tb.sb [cache_scoreboard_c]
UVM_INFO ../uvm/cache_scoreboard_c.sv(414) @ 1765: uvm_test_top.tb.sb [cache_scoreboard_c] Expected activity is not observe do not the system bus
UVM_INFO ../uvm/cache_scoreboard_c.sv(414) @ 1765: uvm_test_top.tb.sb [cache_scoreboard_c] Expected SBUS Packet

Name Type Size Value

expected bus_req_type untegral 32 'haaaa5555
req_address integral 32 'haaaa5555
```

**4. Debug Process** - Verified outputs from the waveform by simulating the test (read\_miss\_icache.sv) and observed that Block serviced by LV1 instead of LV2 which means that block should have been replaced but was not replaced. Bus\_lv1\_lv2\_req\_proc did not assert high



- 5. Erroneous RTL file name lru\_block\_lv1.sv
- 6. Lines of RTL file responsible for the bug (mention the line numbers and lines of the bug)

Line no 38. BLK1\_REPLACEMENT: lru\_replacement\_proc = 2'b10; Line no 39. BLK2\_REPLACEMENT: lru\_replacement\_proc = 2'b01;

7. Corrected RTL code (only mention the corrections)

Line no 38. BLK1\_REPLACEMENT: lru\_replacement\_proc = 2'b01; Line no 39. BLK2\_REPLACEMENT: lru\_replacement\_proc = 2'b10;

## 8. Corrected Waveform



Read request being serviced by L2 as block was replaced.

## 9. Corrected log:

```
UVM_INFO ../uvm/cpu_monitor_c.sv(59) @ 1745: uvm_test_top.tb.cpu[3].monitor [cpu_monitor_c] TRIGGERED ICACHE PACKET CREATION UVM_INFO ../uvm/system_bus_monitor_c.sv(67) @ 1775: uvm_test_top.tb.sbus_monitor [system_bus_monitor_c] Packet creation trig
gered
UVM_INFO ../uvm/system_bus_monitor_c.sv(107) @ 1815: uvm_test_top.tb.sbus_monitor [system_bus_monitor_c] Bus read or bus rea
UVM_INFO ../uvm/system_bus_monitor_c.sv(125) @ 1825: uvm_test_top.tb.sbus_monitor [system_bus_monitor_c] Packet to be writte
UVM_INFO ../uvm/cache_scoreboard_c.sv(539) @ 1845: uvm_test_top.tb.sb [cache_scoreboard_c] cpu_mon_packet from CPU3:
                                                     Size Value
Name
                         Type
packet
                         cpu_mon_packet_c
                                                               'haaaa5555
'h30020000
   dat
                         integral
   address
                         integral
   num_cycles
illegal
                         integral
                                                               'h1
'h0
                         integral
      quest_type
                         request_t
                                                               READ_REQ
                         addr_t
   addr_type
                                                               TCACHE
UVM_INFO ../uvm/cache_scoreboard_c.sv(293) @ 1845: uvm_test_top.tb.sb [cache_scoreboard_c] CHECK_DATA CPU3
UVM_INFO ../uvm/cache_scoreboard_c.sv(295) @ 1845: uvm_test_top.tb.sb [cache_scoreboard_c] Data match!!! expected = aaaa5555
received = aaaa5555

UVM_INFO ../uvm/cache_scoreboard_c.sv(430) @ 1845: uvm_test_top.tb.sb [cache_scoreboard_c] System bus activity matched for t his request

UVM_INFO ../uvm/cache_scoreboard_c.sv(431) @ 1845: uvm_test_top.tb.sb [cache_scoreboard_c] Expected & Received SBUS Packet
Name
                                                                       Size Value
s_packet
                                              sbus_packet_c
   bus_req_type
bus_req_proc_num
req_address
                                                                       32
32
                                                                                BUS_RD
REQ_PROC3
                                              bus_req_t
                                             bus_req_proc_t
integral
                                                                                 'h30020000
  req_address
bus_req_snoop
req_serviced_by
rd_data
wr_data_snoop
snoop_wr_req_flag
cp_in_cache
shared
                                              integral
serv_by_t
integral
                                                                                'h0
                                                                       32
                                                                                SERV_L2
                                                                                'haaaa55555
'h0
                                              integral
                                               integral
                                              integral
                                                                                 'h0
                                                                                 'hΘ
                                              integral
   snared
service_time
proc_evict_dirty_blk_addr
proc_evict_dirty_blk_data
proc_evict_dirty_blk_flag
                                              integral
                                                                       32
32
                                              integral
                                                                                 'h0
                                              integral
                                              integral
                                                                                 'h0
```